/**
 * Created by Dean on 2017/5/4.
 */
var wechatPay = function(orderId,url,callback){
    $.ajax({
        url:_basePath + "app/order/wechatPay?orderId="+orderId+"&url="+url,
        dataType:"json",
        success:function(data){
            if(typeof data.resCode != undefined && data.resCode == 0){
                wx.config({
                    debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来，若要查看传入的参数，可以在pc端打开，参数信息会通过log打出，仅在pc端时才会打印。
                    appId: data.resultList.appid, // 必填，公众号的唯一标识
                    timestamp: data.resultList.timeStamp, // 必填，生成签名的时间戳
                    nonceStr: data.resultList.nonceStr, // 必填，生成签名的随机串
                    signature: data.resultList.signature,// 必填，签名，见附录1
                    jsApiList: [
                        'checkJsApi',
                        'chooseWXPay'] // 必填，需要使用的JS接口列表，所有JS接口列表见附录2
                });
                wx.ready(function(){
                    //支付
                    wx.chooseWXPay({
                        timestamp: data.resultList.timeStamp, // 支付签名时间戳，注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符
                        nonceStr: data.resultList.nonceStr, // 支付签名随机串，不长于 32 位
                        package: "prepay_id="+data.resultList.prepay_id, // 统一支付接口返回的prepay_id参数值，提交格式如：prepay_id=***）
                        signType: "MD5", // 签名方式，默认为'SHA1'，使用新版支付需传入'MD5'
                        paySign: data.resultList.paySign, // 支付签名
                        success: function (res) {
                            // 支付成功后的回调函数
                            WeixinJSBridge.log(res.err_msg);
                            //alert("支付接口:"+res.err_code + res.err_desc + res.err_msg);
                            if(!res.err_msg){
                                //支付完后.跳转到成功页面.
                                if (typeof callback === "function"){
                                    callback();
                                }
                            }
                        }
                    });
                    // config信息验证后会执行ready方法，所有接口调用都必须在config接口获得结果之后，config是一个客户端的异步操作，所以如果需要在页面加载时就调用相关接口，则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口，则可以直接调用，不需要放在ready函数中。
                });
                wx.error(function(res){
                    // config信息验证失败会执行error函数，如签名过期导致验证失败，具体错误信息可以打开config的debug模式查看，也可以在返回的res参数中查看，对于SPA可以在这里更新签名。
                });
                wx.checkJsApi({
                    jsApiList: ['chooseWXPay'], // 需要检测的JS接口列表，所有JS接口列表见附录2,
                    success: function(res) {
                        //alert("检测接口:"+res.err_msg);
                    }
                });
            }else{
                mui.toast(data['message']);
            }
        }
    })
};